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DETAILED ACTION 

1 . This action is response to communication: filed on 02/25/2002 with 
acknowledgement of preliminary amendment received 6/10/2002. 

2. Claims 1-47 are currently pending in this application. Claims 1 , 12, 21 , 32, and 
39 are independent claims. 

3. The IDS received 02/25/2002, 06/1 0/2002, 06/27/2002, 1 0/04/2002, 1 1 /27/2002, 
04/25/2003, 04/28/2003, 08/20/2003, 08/22/2003, 09/02/2003, 12/06/2003, 12/22/2003, 
03/30/2004, 04/02/2004, 06/30/2004, 12/03/2004 have been accepted. 

4. The applicants are encouraged to notify the Examiner if they believe the 
documents submitted in the IDS are more relevant than the art the Examiner has used 
for this rejection. 

5. Claims 1-6, 8, and 32-37 have been amended, and claims 39-47 have been 
added. 



Claim Rejections ■ 35 USC §112 

6. The following is a quotation of the second paragraph of 35 U.S.C. 112: 

The specification shall conclude with one or more claims particularly pointing out and distinctly 
claiming the subject matter which the applicant regards as his invention. 

7. Claim 10 is rejected under 35 U.S.C. 1 12, second paragraph, as being indefinite 
for failing to particularly point out and distinctly claim the subject matter which applicant 
regards as the invention. 
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As per claim 10, the recitation of trademarks such as Windows® should not be 
included in claims. Trademarks can change over time, and impact indefinite language 
to claims. 

Claim Rejections - 35 USC § 102 

8. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 102 that 
form the basis for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 

(e) the invention was described in (1) an application for patent, published under section 122(b), by 
another filed in the United States before the invention by the applicant for patent or (2) a patent 
granted on an application for patent by another filed in the United States before the invention by the 
applicant for patent, except that an international application filed under the treaty defined in section 
351(a) shall have the effects for purposes of this subsection of an application filed in the United States 
only if the international application designated the United States and was published under Article 21(2) 
of such treaty in the English language. 

9. Claims 1-7, 9, 1 1-44, and 46-47 are rejected under 35 U.S.C. 102(e) as being 
anticipated by England et al. US Patent No. 6,938,164 (hereinafter '164). 

As per independent claim 1, '164 teaches a method of loading a trustable 
operating system. A region of memory is identified (col. 2 lines 16-21 and col. 4 line 54 
to col. 5 line 12) by a processor. This computer may have multiple processors (col. 3 
lines 9-13). Content is then loaded into this identified region (col. 5 lines 5-20). The 
processor then jumps to a known entry point in the content (col. 1 1 line 63 to col. 12 line 
20). 

As per claim 2, preventing interference with the identifying, loading, and 
registering by at least one of a remaining one of the plurality of processors are taught in 
col. 2 lines 1 1-25. '164 dictates "According to one aspect, a memory controller prevents 
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CPUs and other I/O bus masters from accessing memory during a code (for example, 
OS, microkernel, or other trusted core) initialization process." Since this method 
prevents CPUs to access memory, it will restrict it from identifying, loading, and 
registering as memory cannot be accessed. Identifying, loading, and registering is 
taught in col. 9 line 57 to col. 1 0 line 1 1 . 

As per claim 3, preventing interference comprises halting at least one of the 
remaining ones of the plurality of processors until the identifying, loading, and 
registering is complete (col. 2 lines 10-25). The other processors are halted as they are 
being reset. '164 dictates "Once an initialization process has been executed by that 
CPU, the code is operational and any other CPUs are allowed to access memory (after 
being reset), as are any other bus masters (subject to any controls imposed by the 
initiated code)." Identifying, loading, and registering is taught in col. 9 line 57 to col. 10 
line 11. 

As per claim 4, causing at least one of the remaining ones of the plurality of 
processors to jump to the known entry point in the content is taught in col. 2 lines 10-25, 
as it states that "other CPUs are allowed to access memory" after the initialization 
process is complete. 

As per claim 5, identifying comprises receiving a region parameter, the region 
parameter specifying a location of the region. This is taught in col. 9 lines 59-62, where 
it indicates that the start parameter "refers to the location in memory 1 10 where trusted 
core 146 begins (e.g., the memory address of the first instruction of platform trusted 
code portion 148)." 
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As per claim 6, the location comprises a range of addresses in the memory of the 
computer within which the region is located. Addresses are taught already in the 
rejection for claim 5 above, and can also be found in col. 1 1 line 63 to col. 12 line 20 
and also col. 14 lines 55-65. Also, col. 10 line 55 to col. 1 1 line 15 indicate a range of 
addresses that can be accepted. 

As per claim 7, the location comprises a start address and a length of the 
memory of the computer within which the region is located. This is taught in col. 9 lines 
57-67: "the Trusted Core Initialization command includes three parameters: start, 
length of code, and length of memory ... the start parameter refers to the location in 
memory where trusted core begins (e.g., the memory address of the first instruction...". 

As per claim 9, '164 teaches that the content is a component of an operating 
system to operate the computer. Col. 5 lines 13-20 indicate this. "Various components 
144 of an operating system are thus laded into memory 110 ... ." 

As per claim 11, '164 teaches that loading and registering are uninterruptible. 
Col. 14 lines 45-54 indicate that interrupts are disallowed during the initialization 
process. It is already rejected in the above claims that the initialization process 
comprises loading and registering. 

As per independent claim 12, '164 teaches halting all but one of plurality of 
central processing units in a computer (col. 2 lines 10-25). A region of memory is 
identified (col. 2 lines 16-21 and col. 4 line 54 to col. 5 line 12) by a processor. This 
computer may have multiple processors (col. 3 lines 9-13). Content is then loaded into 
this identified region (col. 5 lines 5-20). The processor then jumps to a known entry 
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point in the content (col. 1 1 line 63 to col. 12 line 20). Blocking access to the identified 
region by all resources except the non-halted CPU is taught in col. 10 line 55 to col. 1 1 
line 15. Recording a cryptographic hash of the content of the identified region is taught 
in col. 5 line 49 to col. 6 line 5. Causing the non-halted CPU to begin executing at a 
known entry point in the identified region is taught in col. 1 1 line 63 to col. 12 line 20. 

As per claim 13, '164 teaches that the data that causes the machine to halt all 
but one of a plurality of CPUs comprises data causing the all but one of a plurality of 
CPUs to enter a halted state: "CPUs can be prevented form issuing read and write 
requests on processor bus 1 12, or by issuing a halt (e.g., HLT) command to the CPUs 
which halts the operation of each CPU until it resets" (col. 10 lines (62-67). 

As per claim 14, '164 teaches that the data further causes the halted CPUs to 
exit the halted state after the non-halted CPU has begun executing at the known entry 
point in the identified region. This is taught in col. 2 lines 10-25, where the CPUs are 
reset and allowed to access memory through the initiated code. 

As per claim 15, '164 teaches in col. 2 lines 10-25 that the data further causes 
the previously hated CPUs to begin executing at the known entry point in the identified 
region upon exiting the halted state: "Once an initialization process has been executed 
by that CPU, the code is operational and any other CPUs are allowed to access 
memory (after being reset), as are any other bus masters." 

As per claim 16, '164 teaches recording the computed cryptographic hash in a 
hash digest area in col. 5 line 49 to col. 6 line 5. It indicates that the digest can be 
found in a register, which is a hash digest area. Computing the cryptographic has of the 
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identified region is taught in col. 5 lines 49-65. A required platform information is 
recorded in the hash digest area, as '164 indicates that the digest contains a value hat 
can be considered to uniquely represent the trusted core in use. Erasing a hash digest 
area (which is a register) is taught in col. 12 lines 31-39. This section teaches that a 
CPU clears the states of the CPU, which is located in the registers. 

As per claim 17, '164 teaches in col. 5 line 49 to col. 6 line 5 that a hash digest 
area is a register in the memory of the computer. 

Claim 18 is being rejected using the same basis of arguments used to reject 
claim 5. 

Claim 19 is being rejected using the same basis of arguments used to reject 
claim 6. 

Claim 20 is being rejected using the same basis of arguments used to reject 
claim 7. 

As per independent claim 21 , '164 teaches halting all but one of plurality of 
central processing units in a computer (col. 2 lines 10-25). Blocking access to the 
identified region by all resources except the non-halted CPU is taught in col. 10 line 55 
to col. 1 1 line 15. Recording a cryptographic hash of the content of the identified region 
is taught in col. 5 line 49 to col. 6 line 5. Placing the non-halted CPU into a known 
privileged state is taught in col. 6 lines 38-63. 

As per claim 22, jumping to a known entry point in the region is taught in (col. 1 1 
line 63 to col. 12 line 20). 
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As per claim 23, '164 teaches that halting comprises causing the all but one of a 
plurality of CPUs to enter a special halted state (col. 10 line 55 to col. 1 1 line 15). This 
halted state is special as only the CPUs that need to be halted receive this 'HLT 
command. 

As per claim 24, '164 teaches exiting the special halted state after the non-halted 
CPU has begun executing at the known entry point in the identified region. This is 
taught in col. 2 lines 10-25, where the CPUs are reset and allowed to access memory 
through the initiated code. 

As per claim 25, '164 teaches in col. 2 lines 10-25 that the data further causes 
the previously hated CPUs to begin executing at the known entry point in the identified 
region upon exiting the special halted state: "Once an initialization process has been 
executed by that CPU, the code is operational and any other CPUs are allowed to 
access memory (after being reset), as are any other bus masters." 

Claim 26 is rejected using the same basis of arguments used to reject claim 16. 

Claim 27 is rejected using the same basis of arguments used to reject claim 17. 

As per claim 28, col. 5 lines 49-65 teach computing a cryptographic hash of the 
region's contents. Something that can perform a digest hashing function can be 
considered a digest signing engine. This is coupled to the memory of a computer, as 
the hash digest is stored. This is also described in col. 1 1 lines 45-62. 

Claim 29 is being rejected using the same basis of arguments used to reject 
claim 5. This location is secured, as taught in col. 9 lines 62-67. 
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Claim 30 is being rejected using the same basis of arguments used to reject 
claim 6. Col. 1 1 line 63 to col. 12 line 20 indicate that the addresses are of the trusted 
core, which is secure. 

Claim 31 is being rejected using the same basis of arguments used to reject 
claim 7. This region is secured, as this is part of the initialization sequence by the 
trusted core. 

As per independent claim 32, '164 teaches an apparatus to load a trustable 
operating system. '164 is directed toward an apparatus that can allow code to be 
securely initiated in a computer, which can be considered a start secure operation. CoL 
2 lines 10-25 teaches that a processor initiates the process. This startup operation has 
a memory region parameter, as these lines discuss a memory controller and a 
restriction of access to a memory by other processors when initialization has started. 
Blocking access to a region of memory is taught in these lines as well, as it dictates that 
a memory controller prevents other CPUs to access the memory. Content is then 
placed into this memory, as described in col. 5 lines 13-20. A cryptographic hash of the 
content of the specified region is recorded in the hash digest, as described in col. 5 lines 
49-65. This can also be erased, as taught in col. 12 lines 31-39. This section teaches 
that a CPU clears the states of the CPU, which is located in the registers. Unblocking 
access is taught in col. 2 lines 10-25, where access is allowed after the initialization 
process and the other CPUs are reset. Jumping to a known entry point in the content of 
the specified region is taught in col. 1 1 line 63 to col. 12 line 20. It is noted that the 
claim states Is capable/ A system 'capable' to perform an action indicates that the 
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method is not prohibiting the action from happening. Thus, anything that doesn't stop 
these things from occurring appears to meet the claim limitations. This holds true for 
claims 32-37. 

As per claim 33, '164 teaches in col. 10 line 55 to col. 1 1 line 15 that a second 
processor is prevented from interfering with the first processor's initialization process 
(SS). The other CPUs can execute this process, as indicated in these lines, and this 
process can be named a join secure operation (JSO). 

As per claim 34, '164 teaches in col. 2 lines 10-25 that when the first processor 
undergoes the initialization process (SSO), the other CPUs undergo a process in which 
they cannot interfere with the initialization process (JSO). 

As per claim 35, the second processor enters a halted state until the first 
processor's execution of the initialization process (SSO) is complete. This is taught in 
col. 10, lines 55-67, where CPUs are halted until they are reset. It is taught in col. 2 
lines 10-25 that the CPUs are reset after the first processor has been executed. 

As per claim 36, '164 teaches in col. 2 lines 10-25 that a second processor exits 
the halted state after the first processor's execution of the SSO is complete. This 
section also indicates that the second processor is then allowed to access the memory 
in which it was restricted from earlier. 

Claim 37 is being rejected using the same basis of arguments used to reject 
claim 28. Col. 5 lines 49-65 teach computing a cryptographic hash, and a digest signing 
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engine would be necessary for a computing element to compute this hash. Details are 
also found in col. 1 1 lines 45-62. 

As per claim 38, the cryptographic hash is stored in the digest 138 or in a 
register, as indicated in col. 5 line 49 to col. 6 line 5. This is outside the specified region 
memory 110 indicated in col. 5 lines 21-25. 

As per independent claim 39, '164 teaches a method of loading a trustable 
operating system. Selecting an area in a memory accessible to a processor is taught in 
col. 2 lines 10-25, where it indicates that it allows a CPU to access a memory at a 
particular location. Loading a data into the selected area is taught in col. 5 lines 13-30. 
Directing the processor to commence processing at an entry point in the selected area 
is taught in col. 1 1 line 63 to col. 12 line 20. And preventing interruption of selecting, 
loading, and directing is taught in col. 2 lines 1 1-25. '164 dictates "According to one 
aspect, a memory controller prevents CPUs and other I/O bus masters from accessing 
memory during a code (for example, OS, microkernel, or other trusted core) initialization 
process." Since this method prevents CPUs to access memory until the first processor 
finishes initializing and the other CPUs are reset, it will prevent the selecting, loading, 
and directing until they are completed. The selecting, loading, and directing taught 
above are part of the initialization process. 

As per claim 40, halting any other processors having access to the memory until 
the selecting, loading, and directing is complete is taught in col. 10 line 55 to col. 1 1 line 
15. These processors are halted until they are reset, and they are reset after the 
initialization process is complete, as indicated in col. 2 lines 10-25. 
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As per claim 41, causing the other processors to commence processing at an 
entry point in the selected area is taught in col. 2 lines 10-25, where the other CPUs are 
allowed to access the memory. It is also taught in col. 10 line 55 to col. 1 1 line 15 that 
the other CPUs are allowed to access the memory within an address range of the 
trusted core memory. 

As per claim 42, receiving a parameter specifying a location of the area to be 
selected is taught in col. 9 lines 59-62, where it indicates that the start parameter "refers 
to the location in memory 1 10 where trusted core 146 begins (e.g., the memory address 
of the first instruction of platform trusted code portion 148)." 

As per claim 43, the location comprises a range of addresses in the memory of 
the computer within which the region is located. Addresses are taught already in the 
rejection for claim 5 above, and can also be found in col. 1 1 line 63 to col. 12 line 20 
and also col. 14 lines 55-65. Also, col. 10 line 55 to col. 1 1 line 15 indicate a range of 
addresses that can be accepted. 

As per claim 44, the location comprises a start address and a length of the 
memory of the computer within which the region is located. This is taught in col. 9 lines 
57-67: "the Trusted Core Initialization command includes three parameters: start, 
length of code, and length of memory ... the start parameter refers to the location in 
memory where trusted core begins (e.g., the memory address of the first instruction...". 

Claim 46 is rejected using the same basis of arguments used to reject claim 9. 
The memory resides in this device, as it is an internal memory, as indicated in col. 5 
lines 5-12. 
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As per claim 47, '164 indicates in col. 5 lines 13-20 that the operating systems 
can be Windows® operating systems. It is inherent that Windows® has a graphical 
user interface. 

Claim Rejections - 35 USC § 103 

10. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made, 

1 1 . Claims 8 and 45 are rejected under 35 U.S.C. 103(a) as being unpatentable over 
'164 as applied above, and further in view of Bruce Schneier' s Applied Cryptography, 
Second Edition, 1996. 

As per claim 8/164 teaches registering an identity of the content of the identified 
region. Recording a hash digest of the content of the identified region is taught in col. 5 
line 49 to col. 6 line 5. A hash digest is stored in the register, as indicated in col. 6 lines 
4-5. However, signing the hash digest is not expressly taught in '164, but is taught by 
Schneier. Schneier teaches in pages 38-39 the signing of a hash digest which third 
parties can verify. Third parties can verify this, as it is stated in Schneier that the 
documents may be copyrighted. 

At the time of the invention, it would have been obvious to one of ordinary skill in 
the art to include signing a hash digest in a system that registers an identity using a 
hash digest protocol. One of ordinary skill in the art would have been motivated to 
perform such an addition to save time. Schneier dictates on page 38 that "To save 
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time, digital signature protocols are often implemented with on-way hash functions.... 
Instead of signing a document, Alice signs the hash of the document." Also, '164 
indicates that additional information on hashing can be found in Schneier: "the reader is 
directed to a text written by Bruce Schneier and entited "Applied Cryptography: 
Protocols, Algorithms, and Source Code in C," published by John Wiley & Sons with 
copyright 1994 (or second edition with copyright 1996)" (col. 5 lines 61-65). 

Claim 45 is rejected using the same basis of arguments used to reject claim 8 
above. Registering an identity of the data loaded in the selected area is taught in the 
rejection for claim 2 above and also in col. 5 lines 49 to col. 6 line 5. 

12. Claim 10 is rejected under 35 U.S.C. 103(a) as being unpatentable over '164 as 
applied above, and further in view of ATPM - Review: Virtual PC 4.0 (April 2001), by 
Gregory Tetrault. 

As per claim 10, col. 5 lines 13-20 indicate various operating systems. These 
lines describe the Windows® operating systems. A privileged software nucleus is 
taught in col. 6 lines 38-63, in which different privilege levels are taught. However a 
virtual machine monitor is not taught in '164. However, this is taught in ATPM's review 
of Virtual PC, reviewed by Gregory Tetrault. ATPM indicates that Windows® supported 
virtual machine. 

At the time of the invention, it would have been obvious to one of ordinary skill in 
the art to include the use of virtual machines when using Windows® operating systems. 
One would have been motivated to perform such an addition, because a virtual machine 
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is an option provided by operating systems such as Windows®, and is useful for 
networking. Col. 3 lines 4-14 of '164 indicates that the invention can apply to network 
PCs as well, and a virtual machine is an example of a network PC. 



1 3. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Jason K. Gee whose telephone number is (571 ) 272- 
6431 . The examiner can normally be reached on M-F, 7:00 am to 4:30 pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Gilberto Barron can be reached on (571) 272-3799. The fax phone number 
for the organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 

Jason Gee 
Patent Examiner 
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